package com.medicalservice.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.time.LocalDateTime;

/**
 * 医院科室信息实体类
 */
@Data
@TableName("department")
public class Department {

    /** 科室ID */
    @TableId(type = IdType.AUTO)
    private Integer id;

    /** 科室名称 */
    private String name;

    /** 科室编码 */
    private String code;

    /** 科室描述 */
    private String description;

    /** 科室位置 */
    private String location;

    /** 科室电话 */
    private String phone;

    /** 科室负责人 */
    private String director;

    /** 挂号费 */
    @TableField("registration_fee")
    private Integer registrationFee;

    /** 科室状态：1-正常，0-停用 */
    private Integer status;

    /** 排序 */
    @TableField("sort_order")
    private Integer sortOrder;

    /** 创建时间 */
    @TableField("create_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime createTime;

    /** 更新时间 */
    @TableField("update_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime updateTime;

    // 扩展字段（不映射到数据库）
    /** 科室医生数量 */
    @TableField(exist = false)
    private Integer doctorCount;

    /** 科室状态名称 */
    @TableField(exist = false)
    private String statusName;


}
